#include "iostream"
#include "algorithm"
#define MIN(x,y) x<y?x:y
using namespace std;
int dp[2001][1001];
bool comp(int a,int b){
	return a<b	;
}
int main(){
	int n,k,a[2001],aa[2001],i,j;
	while(cin>>n>>k){
	for(i=1;i<=n;i++){
		cin>>a[i];
	}
	sort(a+1,a+n+1,comp);
	for(i=1;i<=n-1;i++){
		aa[i]=(a[i+1]-a[i])*(a[i+1]-a[i]);
	}
	dp[2][1]=aa[1];
	for(i=0;i<=n;i++){
		dp[i][0]=0;
	}
	for(i=3;i<=n;i++){
		for(j=1;j+j<i;j++){
			dp[i][j]=MIN(dp[i-1][j],dp[i-2][j-1]+aa[i-1]);
		}
		if(j+j==i){
			dp[i][j]=dp[i-2][j-1]+aa[i-1];
		}
	}
	cout<<dp[n][k]<<endl;
	}
	return 0;
}

/*
3 1
1 4 6
4 1
1 4 6 7
4 2
1 4 6 7
5 2
1 4 6 7 8
5 1
1 4 6 7 8
*/
